package leetcode; /**
 * description:
 * author:zt
 * date:2021-08-16
 */

import java.util.LinkedList;

/**
 * 有 n 个城市，其中一些彼此相连，另一些没有相连。如果城市 a 与城市 b 直接相连，且城市 b 与城市 c 直接相连，那么城市 a 与城市 c 间接相连。
 *
 * 省份 是一组直接或间接相连的城市，组内不含其他没有相连的城市。
 *
 * 给你一个 n x n 的矩阵 isConnected ，其中 isConnected[i][j] = 1 表示第 i 个城市和第 j 个城市直接相连，而 isConnected[i][j] = 0 表示二者不直接相连。
 *
 * 返回矩阵中 省份 的数量。
 */
public class leetcode547 {
    public int findCircleNum(int[][] isConnected) {
        boolean[] flag = new boolean[isConnected.length];
        int ans = 0;
        LinkedList<Integer> queue = new LinkedList<>();
        for (int i = 0; i < isConnected.length; i++) {
            if (!flag[i]){
                flag[i] = true;
                queue.offer(i);
                while (!queue.isEmpty()){
                    int node = queue.poll();
                    flag[node] = true;
                    for (int j = 0; j < isConnected[node].length; j++) {
                        if (isConnected[node][j]==1 && !flag[j] && j!=i) queue.addLast(j);
                    }
                }
                ans++;
            }
        }
        return ans;
    }
}
